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High-Sensitivity X-Y Recorder Has 
Few Input Restrictions 

To match its high sensitivity, this new recorder provides 
130 dB of common-mode rejection for virtually any input 
configuration. No external "guard" connection is needed 
unless the common-mode voltage exceeds ten volts peak. 

by Donald W. Huff, Daniel E. Johnson, and John M. Wade 



THE NEW MODEL 7047 A RECORDER is the fastest, 
most sensitive X-Y recorder ever built by Hewlett- 
Packard. This rugged, reliable, one-pen laboratory re- 
corder (Fig. 1 ) has maximum input sensitivity of 0.02 
millivolts per centimetre on both axes. It is capable of 
slewing at more than 76 cm/s and of accelerating at 
rates exceeding 5080 and 7620 cm/s on the X and Y 
axes, respectively. 

Making the high sensitivity usable is a special com- 
mon driver amplifier circuit that, acting as an inter- 
nally driven guard, provides 130 dB common-mode 
rejection with virtually any input configuration. This 
is a significant difference from other recorders, which 
require that the LO input terminal always be con- 
nected to the low side of the source if high common- 
mode rejection is needed. No external "guard" con- 
nection is required by the 7047A unless the common- 
mode voltage exceeds ten volts peak. 

Standard features of the 704 7 A Recorder are twelve 
calibrated dc input ranges on each axis, a time base 
that provides six sweep speeds from 0.1 s/cm to 50 s/cm. 
calibrated zero offset with zero control, switchable 
input filters, polarity reversal switches, and remote 
control of many functions by TTL signals or contact 
closures. The servo-motors are continuous-duty alu- 
minum-framed dc motors that do not wear when the 
pen is driven off scale. Chart paper up to 11 by 17 
inches or DIN size A3 is held in place electrostat- 
ically. Pens are disposable, and four colors of ink 
are available. 

Options include metric or English calibration and 
an event marker. 

7047A Design 

The 7047A Recorder is a member of the 7040 Series 
and shares many parts with other members of that ser- 
ies. The basic aluminum mainframe casting is the 
same in all members of the series. The mechanics. 



motors, and servo electronics of the 7047A are the 
same as those of other high-performance members of 
the series. 

The principal differences between the 7047A and 
other members of the 7040 Series are in the preampli- 
fiers that condition the input signals and drive the 
servo electronics. The dc amplifier used in other 
members of the series does not have the very low 



Cover: Our artist's repre- 
sentation of a two-bridge 
measurement that's easy 
lor the 7047 A X-Y Recorder, 
difficult or impossible for 
others Stress-versus-strain 
for an unknown sample is 
measured by applying equal 
forces to the unknown and to 
I a sample of known charac- 
teristics, using the 7047 A to plot one deflection 
against the other. One arm of each bridge is a 
strain gauge. The ac generators represent com- 
mon-mode voltages frequently encountered in 
such measurements. 
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noise and drift required in a high-sensitivity recorder. 
Therefore a new amplifier was designed, using a 
chopper configuration (Fig. 2). It provides the neces- 
sary gain (1200 on the most sensitive range) without 
any significant noise or drift problems 



Fig. 1. Model 7047 A x-Y Re- 
corder has maximum input sensi- 
tivity of 0 02 mVicm (or 0 05 mV/m 
with English scaling) on both axes 
Common-mode 'election is 
greater than 130 dB with 1-kCl 
Impedance in series with either 
input terminal lor both) Six sweep 
speeds, calibrated zero offset, 
polarity switches, and input tillers 
are standard features 



Also because of the new recorder's high sensitivity, 
greater common- mode rejection was required for the 
7047A than for other 7040-Series recorders. Its speci- 
fied common-mode rejection ratio (CMKR) of 130 dB 
is not only 20 dB greater than that of others in the ser- 
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Fig. 2. High sensitivity of the 
7047A Recorder comes from its 
chopper stabilized input pre- 
amplifier. Shown here are a sim- 
plified schematic of the preamp 
and an equivalent circuit (inset) 
lor the most sensitive range The 
preamp acts as a dc operational 
amplifier, A< 
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ies. but guaranteed as well for a l-kll impedance 
in either the Ml or the LO input lead. The input 
configuration is virtually unlimited, as shown in Fig. 3. 
Most recorders cannot operate on their most sensitive 
ranges with the HI terminal grounded and a 1-kJi im- 
pedance at the 1.0 terminal (Fig. 3b). because a notice- 
able line-frequency buzz appears at the pen tip. This 
problem is caused by the unbalance capacitance to 
ground at the secondary of the power transformer, 
which creates a noise voltage and causes a current to 
flow out of the common input or t.o terminal, through 
the unbalance and/or source resistance and then to 
ground. The resulting voltage drop across the resis- 
tance appears as an input signal tojhe recorder. The 
high CMRR requirement plus the need to eliminate 
this noise pump-out current from the LO terminal 
led to the adoption of the "common driver*' scheme. 
This circuit, which is described in detail later in this 
article, represents the biggest single contribution to 
the 7047A's ability to make the wide variety of mea- 
surements it does make. 

The packaging that houses the somewhat sophisti- 
cated front-end electronics of the 7047A (input ter- 
minals, zero-check switch, filter switch, range 
switch, chopper preamp. and common driver) as well 
as various other functions (polarity switch, calibrated 
zero offset switch, zero potentiometer and vernier po- 
tentiometer) consists of two shielded, totally en- 
closed, virtually identical boxes, one for each axis 
(Fig. 4). A protruding cable with multipin connector 
connects each preamplifier to the appropriate servo 
electronics inside the mainframe. 

The casting used to mount the boxes, the time-base 
switches, and power controls is the same as that used 
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to mount the input terminals, various switches, and 
power controls for the older 7046A X-Y Recorder. 
Hence, no new castings were required for the 7047A. 
and except for that associated with the input boxes, 
no new tooling was required. Thus the development 
cost was kept relatively low. and most of the engi- 
neering effort could be directed toward the design of 
the chopper amplifier and the common driver circuit. 

CMR and Noise Problems 

. Recorder amplifier circuits usually have a com- 
mon input terminal. LO, and a high input terminal. 
HI. The input signal V, and source resistances R H 
and R L are connected in series between these termin- 
als, while a common-mode voltage V I M is applied 
to both. See Fig. 5. 

The secondary winding of the transformer in the 
power supply of the instrument usually has an un- 
balance capacitance to ground, C UH . This creates a 
noise voltage V N and causes a current I N to flow out 
of the common input terminal, through the source 
resistance R L and then to ground. The resulting vol- 
tage drop, I^Rl, across the source resistance ap- 
pears as an input signal to the circuit. Hence the true 
input signal is distorted. 

Another problem arises when a common-mode vol- 
tage is applied as shown in Fig. 5. The common-mode 
voltage causes a current I CM to flow through the 
leakage impedance* R«;| |CcG '° ground and back 
to the common mode voltage source. This again 
causes a voltage drop across the source resistance 
Ri , which appears as an input to the circuit and dis- 
torts the true input. 

Several methods have been used to reduce the ex- 

"C u g U n*glrc1efi nete because Cub *-CG 




Fig. 3. 7047 A meets its CMR specifications with any of these 
input configurations 



Fig. 4. Two shieidea boxes house the sophisticates 7047A 
tront-end electronics The ooxes are removable tor servicing 
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Fig. 5. Conventional input amplifiers have problems be- 
cause ol pump-out and common-mode currents /lowing 
through the source resistance. R L 



traneous currents superimposed on the input signal. 
One method is to enclose the secondary windings of 
the power transformer in a box shield. This elimin- 
ates most of the stray capacitance to ground. How- 
ever, since there must be an opening for the trans- 
former wires, the capacitance shield is not complete. 
This method can reduce the stray capacitance by an 
order of magnitude, but is very expensive. 

Another possible solution is to prohibit any input 
resistance between ground and the common input 
terminal. This is unsatisfactory because in many mea- 
surement applications a source resistance cannot be 
avoided. Fig. 3d shows one such situation. 

A third method applies when only one side of the 
input signal has a source resistance. It provides a 
polarity switch that reverses the polarity of the pre- 
amplifier output for the same polarity of input signal. 
By reversing the leads to the input terminals and 
using this polarity switch, the source resistance can 
always be placed in series with the HI input terminal. 
This removes the input resistance from the ex- 
traneous current path and greatly reduces the distor- 
tion of the input signal. This solution, however, is 
inadequate when there is an impedance in both input 
terminals simultaneously (e.g.. bridge measure- 
ments), or when an impedance in series with one 
terminal has to be switched from one terminal to the 
other without adjustments. 

Another method uses separate amplifiers for each 
input terminal followed by a differential amplifier 
to drive the output. The high impedance of the input 
amplifiers prevents any currents from flowing out of 
the input terminals. However, resistor matching 
problems limit the expected common-mode rejection 



to about 80 dB, far below the 130 dB desired for the 
7047A. Another problem with this configuration is 
that the voltage drift of the two input amplifiers has 
an additive effect on the output voltage. Therefore, to 
achieve a given stability both amplifiers must have 
no more than half the drift of the original single pre- 
amplifier. Also, the total noise voltage is approxi- 
mately 40% more than the original noise voltage. 

A widely used method is guarding, or placing an 
electrical shield called a guard around the circuit 
to isolate the circuit from ground. This achieves two 
things. First, the internally generated noise current 
flowing out of the input terminals is greatly reduced. 
Second, high common-mode rejection, especially at 
line frequency, can be realized by driving the guard 
terminal at the common-mode voltage. This diverts 
the common-mode current around the source im- 
pedance in the i.o terminal. Guarding has some draw- 
backs, such as additional cost, and the burden of driv- 
ing a guard terminal properly.' 

The Common Driver Amplifier 

The common driver amplifier used in the 7047A 
permits measurements to be made with better than 
130 dB common-mode rejection at dc and line fre- 
quency with a 1 -k.il resistance in either the III or the 
LO input lead or both. This holds over the full Hew- 
lett-Packard Class B environmental range (0° to 55°C. 
up to 95% relative humidity at 40°C). The effects of 
unbalance capacitance from the power transformers 
are virtually eliminated and a "guard" terminal does 
not have to be driven provided the common-mode 
voltage is less than the output voltage range of an 
operational amplifier in the circuit. Since roughly 
90% of all measurements and recordings taken in- 
volve less than 10V, this voltage was chosen as a rea- 
sonable limiting value. When this voltage is ex- 
ceeded, an auxiliary input terminal icommon MODE 
voltage INPUT) may be driven to circumvent the 
saturation limitation of the amplifier. The only 
shielding required is to isolate the HI and I.o input 
terminals from chassis ground. This shield is con- 
nected to circuit common, which is now an inacces- 
sible point inside the recorder. 

How It Works 

Fig. 6 is a simplified schematic diagram of the com- 
plete 7047A preamplifier, including the common 
driver amplifier. The noise generator V N and unbal- 
ance capacitor C uu represent the current source from 
the power transformer. The leakage impedance 
(R cg ||C C g) 's due to many factors: for example, 
the preamplifier shield, the servo amplifier, and the 
servo motor, all referenced to circuit common, are in 
close proximity to chassis ground. The input signal to 
be amplified is V, and the source resistances in the 
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HI and LO terminal leads are shown as R M and R| . 
respectively. The common-mode source V (;M is 
shown in series with its source resistance R, M . 

The main preamplifier is shown in Fig. 6 as opera- 
tional amplifier A,, Although it actually consists of 
a chopper, an ac amplifier, a demodulator, and an in- 
tegrator, its overall effect is that of a dc operational 
amplifier. A, provides a non-inverting gain of 

K = 1 + R 2 /R, 

for the voltage V, N . which appears across the input HI 
and LO terminals. 

The operational amplifier A 2 inverts the output 
voltage Vqi, t so that, ideally, all of the current flow- 
ing through R 2 and R, because of V 0 i t nas a return 
path through R- and into the output of A.j, The 
potentiometer R, allows a precise adjustment of this 
current sinking so virtually no current flows out of 
the l.o terminal. 

The operational amplifier A 3 , the common driver 
amplifier, has its negative terminal connected to the 
l.o input terminal. It serves to drive the circuit com- 
mon to the same voltage as the voltage applied to 
the LO input terminal. (Note that all three operational 
amplifiers A,. A 2 . and A 3 have their power supplies, 
and hence their outputs, referenced to circuit com- 
mon.) 



Fig. 6. Simplified schematic of 
the 7047 A input circuit. A< is the 
equivalent ol the input preampli- 
fier and A3 is the common driver 

amplifier. The common moot vol 
tage input 'Cmv/j does not have 
to be connected unless the 
common-mode voltage exceeds 
±10 V 

Resistors R H and R,„ and capacitor C are con- 
nected in a series-parallel combination between the 
output of A 3 and chassis ground to provide a shun- 
ting path to ground for the transformer noise coupled 
into the circuit common from the power supply. 
Thus chassis ground forms part of a negative feed- 
back path for amplifier A 3 through the elements 
Rq, R 10 , and C. the common mode voltage source 
V CM and R C m. and the impedance R| . 

The output of A , is also connected to its negative 
input terminal through an alternative feedback path 
consisting of the zener diodes Z, and Z 2 . and the 
diodes D, and D;,. The point B is connected through 
resistor R 8 to circuit common. This diode-resistor 
network activates the alternative feedback path be- 
fore amplifier A, reaches the saturation point. The 
auxiliary common-mode voltage input terminal 
(CMVl) is connected to the output of A , through resis- 
tor R y to provide an alternate reference voltage (in- 
stead of chassis ground) for the output of A, when 
the common-mode voltage exceeds the range of A 3 . 

In normal operation, the common-mode voltage is 
less than the voltage range of A 3 and the cmvi ter- 
minal is not externally connected. The voltage V IN is 
amplified by A, and its feedback resistors R, and R ; . 
The voltage V orT at the output of A,, which is refer- 
enced to circuit common, drives the unity-gain amp- 
lifier A>. which inverts this voltage. Because R 7 equals 
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R,+R 2 , virtually all of the current through R, and 
is drawn through resistor R 7 , and not out of the LO 
terminal. 

Amplifier A , serves as a voltage follower and keeps 
the voltage potential on circuit common equal to the 
voltage on the LO input terminal. The result of this is 
that the currents through R L resulting from V CM and 
V N - are greatly reduced compared to the case shown 
in Fig. 5. Consequently, the CMRR with a resistance 
in the LO terminal is greatly improved and the pump- 
out noise current is virtually eliminated (see Appen- 
dix I). 

The current through R H because of V CM is also con- 
siderably reduced because circuit common is moving 
with respect to ground along with this common- 
mode voltage. Therefore the CMRR with a resistance 
unbalance in the HI terminal is improved signi- 
ficantly (for the 7047 A, at least an order of magnitude 
over the earlier 7045A, which is conventionally 
floated). 

The main limitations on CMRR are imperfect 
shielding between the HI and I.o terminals and chas- 
sis ground, and finite gain in amplifier A 3 . The in- 
put imperfections in the operational amplifiers (off- 
set voltages and bias and offset currents) are not 
serious with appropriate design and component 
selection (see Appendix II). 

When V CM exceeds the range of A 3 the alternative 
diode-resistor feedback path will be activated, un- 
less a voltage within ±10V of V CM is applied at 
the auxiliary cmvi terminal. For the straightforward 
situation of Fig. 6, the best connection is shown by 
the dashed line to point A. In this case A 3 need only 
supply the voltage difference between the common- 
mode voltage applied through the LO input terminal 
and the voltage applied to the CMVl terminal. 

If no signal is applied to the CMVI terminal under 
the above conditions and the alternative feedback 
path is activated, the circuit still functions but it loses 
its ability to shunt to ground the current generated by 
the noise voltage V N , and this flows out of the LO 
input terminal as in Fig. 5. Also, the CMRR is re- 
duced, especially for the case of the 1-kil resistance 
in series with the LO terminal. 

The alternative feedback path for A 3 is especially 
necessary to keep it from saturating when the signal 
source V ( is floating (e.g., a battery) and there is no 
common-mode voltage source. The absence of V CM 
(with R CM = ») disrupts the normal feedback path 
through chassis ground. Without a negative feedback 
path amplifier A 3 would become an open-loop 
amplifier and would lose its ability to reduce the vol- 
tage difference between the LO terminal and circuit 
common to near zero. However, before A 3 reaches its 
saturation point, its output voltage reaches the turn- 
on voltage of zener diodes Z, and Z 2 . The output cur- 



rent of A 3 produces a voltage difference across R a , 
which in turn produces a voltage difference across 
the signal diodes D, and D 2 sufficient to forward bias 
one of them, depending on the polarity of the biasing 
voltage. Thus the alternative negative feedback path 
is activated to keep amplifier A 3 from saturating. 
Other 7047A Features 

The front-panel POLARITY switches, one for each 
axis, determine whether positive signals drive the re- 
corder right-to-left or left-to-right on the X-axis, and 
down-to-up or up-to-down on the Y-axis. Thus the 
user can drive the recorder in a predetermined direc- 
tion regardless of the polarity of the input signal and 
without having to exchange input leads. If he cannot 
drive the CMVI terminal with a common-mode vol- 
tage exceeding 10V, he can use the POLARITY 
switch along with exchanging the input leads to max- 
imize CMR, provided there is no resistance in series 
with the LO terminal. The CMR performance will 
then approximate that of the 7045A Recorder (i.e., 
110 dB at dc and 90 dB at line frequency for a 1-kfi 
resistance in series with the HI terminal). 

The front-panel FILTER switches, one for each ax- 



SPECIFICATIONS 

HP Model 7047A High Sensitivity X-Y Recorder 

TYPE OF INPUT: Front input only. Floating, guarded. Employs a unique common 
driver circuit that eliminates need tor connecting CMV to recorder, it CMV 
5,10V peak 

INPUT RANGES: 0.05, 0.1 , 0.5. 1.5, 10 mV/in ; 0.05. 0.1, 0.5, 1, 5, 10 Win. (metric 

calibration available in 0.02, 0.05. 0.1. 0.5. I, 5 mV/cm: 0.01. 0.05. 0.1. 0.5, t; 5 

V/cm). Continuous vernier between ranges 
INPUT RESISTANCE: 1 megohm constant on all ranges. 
SOURCE RESISTANCE: 10k ohm majtimumon all ranges except .05mV.in. ana 

.1 mV/in. (.02 mV'cm, .05 mV/cm. and .1 mV/cm) where It is 2k ohm maximum. 
ACCURACY: l 0.2% ot lull scale (includes linearity and deadband) at 25'C. Temp 

coefficient :0.01% per "C. 
RANGE ACCURACY: i0.2% of full scale • 0.2% ol deflection (includes linearity 

and deadband) at 25C. Temp coefficient r0.01% per "C. 
DEADBAND: 0.1% ot full scale. 

COMMON MODE REJECTION: 130 dB dc and 130 dB ac with 1k ohm imbalance 
in either the high or low terminal (exceeds 150 dB under normal lab conditions). 
CMR decreases 20 dB per decade step in attenuation trom the most sensitive 
range. 

NORMAL MODE REJECTION: 30 dB minimum al line frequency with FILTER IN. 

(50 dB typical at 60 Hz and 40 dB typical at 50 Hz.) 
SLEWING SPEED: 30 insec (76 cnVsec) minimum. 38 in/sec (97 cm/sec) typical 

under normal lab conditions 
ACCELERATION PEAK: 

Y-AXIS: 3000 In'sec*. (7620 cm'sec*) 

X-AXIS: 2000 in.'sec 1 , (5080 cm/sec J ) 
OVERSHOOT: 1% ol lull scale maximum. 

ZERO OFFSET: Eleven calibrated scales of zero offset in both axes Switchable in 

steps of one full scale trom '1 to -10. 
OFFSET ACCURACY AT 25 C (APPLIES TO CALIBRATED ONLY): '0.1% Of 

full scale times N where N - number of scales of offset. 
OFFSET TEMPERATURE COEFFICIENT: rO.004% ol full scale limes N per C. 
TIME BASE: Standard: 6 speeds; 0.5. 1.5, 10. 50, 100 seo'in (metric calibration 1 

.5, 1. 5, 10. 50 secJcm) switchable into X or Y axis. 
TIME BASE ACCURACY: 1.0% at 25°C. Temp coeflident = 0.1%/*C. 
POWER: 115 or 230 Vac, ±10%, 48 to 66 Hz, 180 VA 
PEN LIFT: Eleclric (remote via TTL level) 
WRITING AREA: 10 ■ 15 in (25 cm ■ 38 cm) 
WEIGHT: Not 41 lb (18.6 kg): shipping 53 lb (24 kg). 
PRICE IN U.S.A.: S2850 Event Marker Option 002, $85 
MANUFACTURING DIVISION: SAN DIEGO DIVISION 

1 6399 West Bernardo Dnve 

San Diego. California 92127 U.S.A. 
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APPENDIX I 

Analytical Expressions For Common-Mode Rejection Ratio and Noise 

Pump-Out Current 



The common drive* amplifier. A t in Fig 6 is shown m the diagram Deiow win 
gam A Also shown are the sources o' !he unwanted current I, . the common-mode 
voltage v\ M and v v "'"■ch is the Tnevenm equivalent o* the nose source V,. 
in F>g 6 thai is 



where 



2iSi 



also trom Fig 6 The Tnevenm equivalent impedance is 
Z 

1-|~C ,fl... 

where 

Cos - C co .C„ 



(1) 



(2) 



(3) 



14. 



The output impedance Z.. is the parallel combination at R. ana C . which are 
respectively R. ana C in Fig 6 The input resistance R is equivalent to the 
senes comc-nalion of R, and fi,. in parallel with R. All components obviously 
insignificant to the analysis are omitted 
We can now wnte the loop equations 



v«,*A(V r -Vj-l l (Ba»*«V»*J-lA ■ o 

and 

Viy MZcQ-ZvI-^Vc-V,)-!^. 0 

Since 

Vc-V, - l,R 
equations |5I and 161 become 



IS) 



(8) 



IT) 




V „ l,|R,.„ (t.A|R .Z I..Z a 
and 

Solving lor I., in equation |9) we have 

v; kz,,-arj 
z ; ,-z„ 

Substituting <10| into (8) we ootain 



ib, 



V ~5 



I 



Zi- 'Z„ 



Zco-Z, 

Unoor ail normal operating conditions it can be assumed that 

IZbj|-..|Z.I 
Al - -I 

AR R C11 -Z. 

Hence 



I, ^ 



AR AR, Z c ., 
Since Irom |1> (2). (3). and |4> 
v '. u 



, 'La 

Afl 



AR 



(•0) 

(11) 

(12) 
(13) 

(14| 

(15) 
(18) 
117) 



The firsl term in equation |17) represents the current resulting Irom the common- 
mode voltage V- u Therefore, tor a resistance R m senes with the LO lermnit. 



A R 

FcH, I kllandR. 300 ktl 
CMRR 300 A 



•8 



.191 



Using design values trom the 7047A we get the following approximate 
values tor CMRR 

2 0 • 10" or 186 dB dc nominal 

1 6 • 10* or 164 dB dc minmum 

6 0 • 10' or 155 d8. 60 Hi nomnal 

4 7 ■ 10* or 133 dB 60 Hi mnmum 
These values agree closely with measured values for me 7047A 

Tne second term in equation H7) represents the current resulting trom the 
power transformer nc-se cutreni Tns is reduced by a factor of AR,Z which 
for the 7047A -s rvtmrnaliy 2-10* absolute value With a 10-Mt source resistance 
and the mi terminal connected to ground thii source of pump-out current was not 
measuraole on the 704 7A 



is. provide more than 20 dB additional normal-mode 
rejection at line frequency when the filter is IN. 
Some degradation of rise time occurs. 
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APPENDIX II 

Effects of Amplifier Offsets 

Tne common driver amplifier Aj irom Fig 6 is shown in the diagram below with its 
associated resistors and an external source resistance or fl. The hi terminal 
is grounded, since this represents a more significant case than when the lO terminal 
is grounded The offset voltage of Ai is shown as a vanac-le cattery vo lan internal 
potentiometer 'S used to adjust its equivalent value) The bias and offset currents of 
Aj may be neglected because a low-leakage dual-input FET 14 used The sum of the 
offset voltage and the product of offset current and dnft compensation resistance R* for 
amplifier A ; in Fig 6 is shown as the fixed battery vcu M|| is the equivalent offset re- 
ferred to the input of the chopper amplifier A. V 0 is the sum of me series batteries v,,.. 
and Haj and V D is tne voltage with respect to circuit common at the negative input of 
Ai V . and V, are the voltages with respect to circuit common at me outputs of A, and 
Aj respectively isee Fig 6) Since a dc analysis is being done an capacitors are 
ignored 

Assuming A 5 to now be an ideal operational amplifier 0 e infinite gam. infinite input 
impedance and zero offset) we can use superposition to wnte 

I ■ V„300MI - Vi/80akfl - V, 60OII 
. V«300M1 - V. 600MI - V. 600(1 v aJ 300MI 
. Vi,30f>ll vojttOOM! 

- (v« • v»i)<300»ll v c; JUO«ii 

- WV300M) 

Hence by aoiusting only the offset voltage v 0J of the common dnver amplifier A, to 
zero the pump-out current I due 10 offsets can be eliminated The effect of dnft m 
amplifier Aj on pump-out current 1 is eliminated by the algebraic cancellation of the 
terms containing v 0 j This is the result of connecting the • terminal of amplifier A> to 
the - terminal of amplifier A; isee Fig 6). a connection whose advantages are not 
obvious at first glance 
The Offset voltage at the output ol the preamplifier is given by 

Vi » -Kv»i - via - v«s 

For the 7047A design the Kvo- term is only significant on the most sensitive ranges 
when K is large Hence, only voj - voj is compensated Dy adding a series equivalent 
low-impedance fixed voltage on a less-sensitive range Kv&. which comes into play 
only on the most sensitive ranges, is tolerated, and typ-caiiy is on the order of a few 
millivolts or an offset of about 0 I cm at the pen tip on the 0 02 mV cm range (the 
sensitivity at the output of the preamplifier is 24. mV'cm on all ranges! 



600k 1! 
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Digital High-Capacitance Measurements 



to One Farad 

Here's a new high-C meter capable of measuring today's 
wide-value electrolytic and tantalum capacitors. It's for 
production testing, incoming inspection, and the laboratory. 

by Kunihisa Osada and Jun-ichi Suehiro 



4 



HEWLETT-PACKARD'S MODEL 4350A/B High- 
Capacitance Meter 1 , first produced in 1971, had 
a wide measurement range (1/liF to 300 mF) and si- 
multaneously measured capacitance and dissipation 
factor, features that were considered advanced at the 
time. Since 1971. however, the capacitor industry 
has made considerable progress. Manufacturers of 
high-value electrolytic capacitors, used in computer 
power supplies and many other applications, now 
routinely produce capacitors as large as one farad. 
Tantalum capacitors are now produced in an ex- 
panded rangi.' of values (0.1//F to 1000/iF) with 
smaller dissipation factors. 

The new Model 4282 A Digital High-Capacitance 
Meter. Fig. 1. has a measurement range wide enough 
and accuracy high enough to satisfy the present mea- 
surement needs of capacitor makers and users, and 
then some. Its four-digit readout, digital output, and 
remote programmability are expected to make it use- 
lul in production test and incoming inspection sys- 
tems, as well as in the laboratory. 



Model 4282A measures capacitance in nine ranges 
from 10 nanofarads to one farad. Resolution as fine as 
one picofarad is possible. Basic accuracy in capaci- 
tance measurements is 0.4% to 2.5%. depending on 
range. Dissipation factors as high as 10.00 can be 
measured. Resolution is 0.001 and basic accuracy is 
1.5%. 

The new high-C* meter can also measure (he pro- 
duct of capacitance and equivalent series resistance 
and display the result in ohm-farads. Capacitance is 
read on the I.ED four-digit display; dissipation and 
ohm-farads are read using three full digits with a 
fourth for overranging. The reading rate is contin- 
uously variable from 0.3 to 2 seconds, and capaci- 
tance and dissipation factor (or ohm-farad) measure- 
ments can be displayed alternately if desired, thus eli- 
minating the need for resetting panel switches or us- 
ing two instruments. 

Four internal test frequencies are available: 50. 60. 
100 and 120 Hz. An internal dc bias supply is contin- 
uously variable from 0 to 10 volts. 




Fig. 1. Model 4282 A Digital 
High-Capacitance Meter mea- 
sures capacitance to one farad, 
dissipation lactor to WOO. the 
product of capacitance and 
equwatent series resistance (OF), 
and dc voltages to 600V An 
option adds leakage current 
measurements. 
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Manual C Bridge with Voltage Controlled Attenuators 



Fig. 2. A capacitance bridge -nay be balanced by adpjst- 
mg standard capacitors, as shown in (a), or by adjusting 
the gam ot a voltage-controlled attenuator, or multiplier 
as shown in tbi Model 4282A uses the latter approach ad- 
ding a feedback loop so balance Is achieved automatically 

Leakage-current measurement ranges from 1 mi- 
croampere to 10 milliamperes are added with Option 
001. Results are displayed on three digits with 18 per- 
cent overranging. Dc bias from 0 to 100 volts and pro- 
vision for bias from an external source are added to 
the standard instrument with this option. 

Digital and analog output are available on the rear 
panel. Function, range, and reset are independently 
remotely programmable by contact closure to 
ground or TTL/DTL logic levels. 1, with Option 001 
is also programmable. 

In addition to these high-C-meter capabilities. Mo- 
del 4282A can be used as a three-digit dc digital volt- 
meter to measure up to 600 volts. 

Bridge Measurement 

Because the bridge method is the most accurate 



way to measure impedance, the 4282A makes bridge 
measurements. However, the bridge is balanced auto- 
matically, so measurements are much faster than 
with a manual bridge. 

Fig. 2a shows a manual bridge for measuring the ca- 
pacitance and dissipation factor of an unknown. A 
series equivalent circuit is assumed for the un- 
known. The bridge is balanced by adjusting standard 
capacitors C sl and C s;; . At balance. 



For the series equivalent circuit, dissipation factor is 
defined as 

At balance. 
D* = <"C s2 R,,. 

Shown in Fig. 2b is the same bridge, but with ana- 
log multipliers acting as voltage-controlled attenua- 
tors replacing the variable standard capacitors. Bal- 
ance is obtained by varying V, and V,,. At balance, 

li + lei + 'c2 = 0. 

How the New Meter Works 

Fig. 3, the simplified block diagram of the 4282A 
High-Capacitance Meter, has a basic configuration 
similar to that of Fig. 2b. The major difference is that 
in the 4282A the bridge is balanced automatically by 
means of a negative feedback loop consisting of mul- 
tipliers, a summing amplifier, synchronous detec- 
tors, and integrators. 

The test signal from the meter's internal oscillator 
is applied to the unknown through an AGC amplifier 
and a power amplifier. A transformer makes it pos- 
sible to apply dc bias to the unknown. 

The voltage across the unknown capacitor is ampli- 
fied by A, in Fig. 3. The voltage across the range resis- 
tor R sl is amplified by A ,. The output of amplifier A, 
goes to one of the multipliers, which in turn provides 
current i, , to the summing amplifier through stan- 
dard capacitor C sl . The output of A a goes to the other 
multiplier, which sends current i t > to the summing 
amplifier through standard capacitor C s -,. Reference 
current i, comes to the summing amplifier directly 
from the output of A, through standard resistor R s2 . 

The output of the summing amplifier is divided 
into two parts by the synchronous detectors, which 
produce dc voltages proportional to the real (in- 
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Fig. 3. Simplified circuit diagram of the 4282A Digital High-Capacitance Meter The trans- 
former makes it possible to apply dc bias to the unknown along with the ac test signal a! 50. 60. 

100. or 120 Hz 



phase) and imaginary (quadrature) parts of the cur- 
rent i„ through the unknown. These voltages are 
integrated and the integrator outputs are the second 
inputs to the two multipliers. 

The feedback loop acts to set i d = 0. At balance, 
the input current to both integrators is zero, and the 
integrator output voltages are V,, and V d , which are 
proportional to the unknown capacitance and dis- 
sipation factor, as we will now show. 

The multiplier input voltages in Fig. 3 are 



I 



and 



V 2 = i x R s ,A 2 . 



The output of each multiplier is proportional to the 
product of its two inputs: 

v; = v,v c /k, 

and 



V 2 = V 2 V d /K 2 . 
The currents into the summing amplifier are 

i„ = jwC 8 ,V', 

ic2 - jwQzVi 
and 

ir = V 2 /R 52 = i,R 5 ,A 2 /R s2 . 
When the bridge is balanced. 

id = «cl * 'c2 + 'r = <J- 

Substituting the values above into this equation, set- 
ting the sums of the real and imaginary parts equal to 
zero, and solving for the unknowns gives the follow- 
ing relations: 



K 1 R,j A_> 



and 



12 



© Copr. 1949-1998 Hewlett-Packard Co. 



toC. *fL* 
D x = tuC.R, = — SSV 4 . 

The built-in digital voltmeter measures V, and V',j 
and displays C x and D, directly. Ohm-farads are ob- 
tained by multiplying the dissipation factor by l/<o. 

Four-Terminal Measurement 

Model 4282A has nine decade capacitance ranges, 
from 10 nF full-scale to 1 F. Thus the unknown impe- 
dance may range from milliohms to megohms, and 
the 4282A must be able to cope with the problems of 
both low-impedance and high-impedance measure- 
ments. 

A four-terminal configuration, as shown in Fig. 4. 
is used to eliminate low-impedance measurement er- 
rors caused by test-lead resistances (R| in Fig. 4). 
Two terminals are used to inject current into the un- 
known and two other terminals are used to detect the 
voltage across the unknown. Because lead resistance 
between the unknown and the range resistor R 4| may 
cause an error, two different terminals are used to 
detect the voltage across the range resistor. Very- 
high-input-impedance voltage followers at the vol- 
tage-detection terminals make the tour-terminal con- 
figuration practical for bridge measurements, where 
the unknown voltage and the reference voltage must 
be detected simultaneously while keeping the cur- 
rent in the voltage leads negligibly small compared to 
the current in the current leads. 

Stray Capacitance Compensation 

Capacitance measurement resolution may be as 
fine as 1 pF on the lowest range, so stray capacitance 




Fig. 4. A lour-termma' configuration with very-high-mput- 
impedance voltage followers In the voitage-sensmg leads 
eliminates errors caused by leao resistances 



and amplifier input capacitance must be considered 
a source of error. Of the stray capacitances shown in 
Fig, 5, C, causes mainly capacitance errors and C 2 
causes mainly dissipation factor errors. C 3 does not 
affect measurements. Without compensation, capaci- 
tance errors might be as large as 20% of full scale on 
the lowest range. 

To eliminate these errors, Model 4282A has the 
stray-C compensation circuit shown in Fig. 5. Ampli- 
fiers A 4 and A 5 send compensation currents i 4 and i s 
through capacitors C 4 and C 5 . The result is that 

i, + i 2 + i 4 + i 5 = 0 

so the current that flows through the unknown capaci- 
tor is equal to the current flowing through the range 
resistor. 

For high-voltage protection a pair of zener diodes 
is connected to each input voltage follower as 
shown in Fig. 6. In normal operation there is no ac 
voltage across the diodes that connect the amplifier 
input terminal to the zener diodes, so these diodes 
introduce no distortion and no additional stray 
rapacitance. 

The Multipliers 

The accuracy of the new high-C meter in capaci- 
tance and dissipation factor measurements is mainly 
a function of the linearity of the two multipliers 
shown in Fig. 3. The multipliers, a kind of voltage- 
controlled attenuator, are linear within 0.2% or bet- 
ter from 1/10 of full scale to full scale for both inputs. 

The multiplier circuit. Fig. 7. consists of a pulse- 




Fig. 5. Stray-C compensation circuit makes the current 
through the unknown equal to the current through the range 
resistor R,,. 
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Fig. 6. For high voltage protection, zener diodes are con- 
nected to each input voltage follower Circuit is designed so 
that, in normal operation, no ac voltage appears across the 
diodes, so they introduce no distortion or additional stray 



width modulator followed by a demodulator. The 
duty cycle of the modulator output pulse is propor- 
tional to one of the multiplier input voltages, and the 
gain of the demodulator is proportional to the other 
multiplier input voltage. 

The clock generator in the modulator circuit of 
Fig. 7 produces a sawtooth wave, which fixes the per- 
iod of the modulated pulse. The clock frequency is 
ZOO kHz, far higher than the input signal frequency. 
The input voltage to the zero detector is half the sum 
of the clock generator output voltage and the integra- 
tor output voltage. 

Inputs to the integrator come from the variable 
multiplier input voltage E d . which corresponds to 
V, or V 2 in Fig. 3, and the fixed reference voltage 
±E r . During time T,. the zero detector input vol- 
tage is positive and switch S, connects +E r to the 
integrator. During T 2 . the zero detector input is nega- 
tive and S, switches to -E r . T,+T 2 is equal to the 
(.lock generator period. At steady state the sum of the 



t 2 t, 
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Fig. 7. Multiplier consists ot a pulse width modulator and a demodulator One multiplier input 
varies the duty cycle ol the modulator output pulse, and the other vanes the demodulator gam 
Multiplier linearity is better than 0 2% lor ootn inputs 



14 



© Copr. 1949-1998 Hewlett-Packard Co. 



integrator input currents over the complete period is 
zero. Hence 



V,, is sampled and held on capacitor C Q . At the end 
of the next clock period the integrator output is 



and 



T,-T 2 = - JgflTt+TJ. 



V - V Et>T ' 4. EbT2 V IT *TI 1 

The values of C,. Rf. and the clock period are chosen 
so that 



1-(T 1+ T^=0. 



Thus Tj— T 3 is proportional to the input voltage E a . 
In this closed-loop modulator, the hysteresis of the 
zero detector causes no error. 

In the demodulator circuit of Fig. 7. switch S 2 is 
controlled by the zero detector output pulse. During 
time T 2 . S 2 connects the voltage -E ( , to the integrator, 
where E b is the other multiplier input voltage, cor- 
responding to V r or V d in Fig. 3. During time T,. +E b 
is connected to the integrator. The sample gate sam- 
ples the integrator output voltage V, at the end of each 
period (T,+T 2 ) and capacitor C (l holds the sampled 
voltage. 

Assuming that the integrator output is zero and 
the demodulator output E ou , is also zero at the begin- 
ning of the first period, the integrator output at the 
end of the first period is 



V„ = - 



E b T, | E b T 2 
R,C, RiQ 



Therefore 



V,, = v 12 . 



This means that if T,— T 2 is constant, demodulation 
is completed in one clock period and E oul remains 
constant thereafter, as shown by the waveforms in 
Fig. 7. The output voltage is 



ur b JT, TJ - R 'q R r a E, (T,+T -' 



K,C, 



which is proportional to the product of the Iwu multi- 
plier input voltages E a and E h . 

A simple low-pass filter could have been used 
instead of the integrator and sample-and-hold circuit 
of the demodulator, but there would have been time 
delay and ripple problems. The 4282A approach 
eliminates these. 
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SPECIFICATIONS 






HP Model 4282A Digital High-Capacitance Meter 


MEASURING RANGES: 




Option 001 Leakage Current Measurement 


CAPACITANCE lO.OOOnF lo 1 OOOOF. lour lull digits 9 ranges in decade steps 


RANGE: I.ODOiiA lo 10 00mA 5 ranges, three full digits 


manual selection. IB*, overranging. 




OVERRANGING: IBS 


DISSIPATION FACTOR 1 000 10 10 00 


three lull digits. 2 ranges, auto 


ACCURACY; 


selection, t 


Bs overranging 




1|jA range - (2S of 'eading - 2.0*. ol lull-scale) 


OHM FARAD 


1 OOOllmF to to OOllmF three lull digits. 2 ranges, auto selection. 


10,, A In 10mA nnnoc -1?'- nf roarbrvt - H "i" . i' ft ill-^r Jtlo i 


18°» overranging 




BIAS VOLTAGES: 


DC VOLTAGE 10 00V to t 000k V. three lull digits 3 ranges In decade steps 


INTFRNAL SOURCF 0 to 10V 0(o100V ? rnnaes cAntinuouclu vanaoie BMW 


manual selection (maximum voltage is 600V). IBS overranging 


BoC" IdnQB 


MEASURING CIRCUIT: Senes equivalent circuit using tour-terminal method 


MAXIMUM fllRRFNT 100mA for 10V ranrif* arui fiOmA /frv 1 minule) tor 

Tin" MTium y—f w r iriuiv I . i w y j r ir^ iuv iai Qi wi * in \ i 'mi iviuf ♦ w 1 


MEASURING FREQUENCIES: 50Mj 60Hz. 


00Hz and 120Hz (50Hz and 60Hz 


t OflV frinnn 
' yv y lotua 


synchronized Dy line frequency) Accuracy 


:15V 


EXTERNAL SOURCE: Useable up to 600Vdc across EXT BIAS terminals on 


MEASURING VOLTAGES: 10nF lo 10mF 


ranges -' IVrms : lOOmF range 


lA^t n^n*ni 

o u 1 (JQ 1 lul 


•O.IVrms.. IF range: < lOmVrms. 




PROTECTIVE RESISTOR* 1klt for 100V ranae and tor external txas 111 for 10V 


ACCURACY | • 


23"C :5"C after half hour warm up): -IS ol reading -s ol 


range 


lull scale) 






CAPACITANCE 












oenerai 


C Range 


s of reading 


S of full-scale 


DC BIAS VOLTAGE: 0 to 10V continuously adjustable with DC BIAS control 


10nF 


1 .0 - 0 9 D rdg 


01 


Maximum charging current is 100mA 


tOOnF 


0.5 - 0.5 D rdg 


0 1 


BALANCING TIME: Normally one second Iwhen measuring on C ranges of 


1(»F lo lmF 


0.4 - 0 5 0 rdg 


0 05 


lOnF through lOmF capacitance value near full-scale dissipation lactor less 


lOmF 


10-05 D rdg 


005 


than one and without dc bias) 


tOOmF 


1.5 * 0.5 Dnjg 


05 


READING RATE: Continuously variable from 0 3 seconds lo 2 seconds with 


IF 


2 5.05 D rdg 


1.0 


RATE control 








RESET: Inflates one leading by depressing RESET INT pushbutton or contact 


DISSIPATION FACTOR 




closure lo ground or TTL low level at RESET EXT line 


C Range 


S ol reading 


S of full-scale 


DIGITAL OUTPUT: 


10nF 


1 5 ■ 0 5 D rdg 


0.2 CfsvC rdg - 0.3 


OUTPUT SIGNALS BCD - 1-2-4-8. data parallel, decimal point, function and 


tOOnF to ImF 


1.5 r 0.2 D rdg 


0 2 Cls/C tog - 0 3 


unit, overload and unbalance and polarity 


lOmF 


15-02 D rdg 


0 2 Cls/C rdg - 0 5 


LEVEL Low 0.3V 1 03V. Man sink current 15mA High 3 9V i 1 SV. Max 


lOOmF. 1F 


15 + 0.2 D rdg 


0 2 CIs C rdg - 3 


load current 300 U A 




PRINT COMMAND OUTPUT Negative gang TTL pulse ol appron 1ms 








PRINTER HOLD INPUT TTL low level or contact closure to ground 


OHM-FARAD 






REMOTE PROGRAMMING: All FUNCTIONS. C Range I L Range loption 








001 ) and Reset by TTL low level or contact closure to ground 


C Range 


S of reading 


s of full-scale 


ANALOG OUTPUT: Dc output ol 1V full-scale in proportion to displayed value 


lOnF 


1.0 - 0.5 HF rdg 


02 Cls/C rdg • 0.3 


ACCURACY Add -0 5S ol reading to accuracy specification 


tOOnF to ImF 


1.0-0.2 IIF rdg 


0.2 CisfC rdg • 0.3 


OPERATING ENVIRONMENT: 0 C to - 50 C 90S RH 


10mF 


10-02 IIF rdg 


0 2 Cls/C rdg - O S 


POWER REQUIREMENTS: 100V 120V 220V or 240V - 10*.. 50Hz or 60Hz 


lOOmF. 1F 


10 • 0.2 IIF rdg 


0.2 Cls/C rdg - 3 


appro" 70VA 








DIMENSIONS: 425 W ■ 88 H • 467 D mm 


DC VOLTAGE 




WEIGHT: Net B8 kg 


10V range: 


r(0.05S ol reading - 0 1% ol lull-scaiei 


PRICES IN U.S.A.: 


100V and tkV ranges rf0 2S ol reading • 0 is ol lull-scale). 


HP 4282A. S3500 


TEMPERATURE COEFFICIENT: (referred lo 1 23 C and temperature range ol 


HP 4282 with Option 001, S3750 


0"C lo 50 C) 






MANUFACTURING DIVISION: YOKOGAWA-HEWLETT -PACKARD LTD 


C :0 02S 


ol reading'C 




9-1, Takakura-cno 


D IIF r003S ol reading'C 




Hachtoji-sh* 


V :001S 


ol reading'C 




Tokyo 1 92 Japan 
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Computer Performance Improvement by 
Measurement and Microprogramming 

The speed of a computer-based Fourier analyzer was 
increased by a factor of ten by creating several new 
machine language instructions using firmware. Areas 
to be microprogrammed were selected on the basis 
of performance measurements. 

by David C. Snyder 



MICROPROGRAMMING, or microcode, is a 
comparatively old technique for computer de- 
sign. It was first described by Wilkes in 1951. when 
most logic gates were vacuum tubes and the transis- 
tor was only a three-year-old infant. The original ob- 
jective was "to provide a systematic alternative to the 
somewhat ad hoc procedure used for designing the 
control system" of a computer. 1,2 

The control system of a computer implements its 
basic machine-language instruction set. In many 
computers (e.g.. the 1967 vintage HP 2116). this sys- 
tem is a combination of random logic, complicated 
clocking, and special-purpose data paths. In a micro- 
coded computer, a set of primitive operations (gate 
register R3 to bus. gate bus to register Rl. issue ADD 
command, etc.) is first identified. One then builds a 
primitive machine and microprograms the primitive 
machine to emulate the desired machine. 

Microcoding introduces a degree of freedom into 
the design process by breaking one problem, defin- 
ing the desired machine, into two relatively noninter- 
active ones: defining a set of primitives (using hard- 
ware), and microprogramming these primitives to 
emulate the desired machine. 

As the years passed, memory costs (both ROM and 
RAM) dropped, memory speeds rose, and more de- 
signs used microcode. Today one finds microcode 
used in large machines (e.g., most models of the 
IBM 360 and 370). minicomputers (e.g., Hewlett- 
Packard 2 100 and 21 MX. Microdata Model 1600). mi- 
crocomputers (e.g.. National GPCP and Intel MCS-4, 
but not Intel MCS-8), and some calculators (e.g., HP 
35. HP 9830). The benefits to the designer include re- 
duced design time and increased hardware product 
life. The benefits to the user include the ability to in- 
crease performance greatly through the use of low- 
cost, microcoded instructions tailored to the user's 
own problems. 



Where Microcode Fits 

Machine language is the lowest user-program- 
mable level in most computers. FORTRAN or ALGOL 
programs must be translated into this language by 
FORTRAN or ALGOL compilers before the programs 
can run. BASIC and other interpretive languages are 
implemented by machine language programs. As- 
sembly language is translated into machine language 
by an assembler, which replaces instruction mne- 
monics with numerical opcodes. If one were to stop 
a computer and look in its memory, one would find 
machine language programs and their data (num- 
bers, tables, lists, etc.). nothing else. 

All stored-program computers work in the follow- 
ing manner: a program address register (P) contains 
the address of the next machine language instruc- 
tion. That instruction is fetched. P is incremented to 
the next instruction address, and the fetched instruc- 
tion is executed. This pattern then repeats. In a ma- 
chine that is not microcoded. these phases are imple- 
mented via complicated clocking, discretionary wir- 
ing, and control gates arranged in a seemingly ran- 
dom pattern. In a microcoded machine, the execute 
phase — and sometimes fetch, interrupt, and direct 
memory access — is implemented by a microprogram 
that runs in a simpler, more regular microprocessor. 
The advantage of such a machine hierarchy — imple- 
menting the "2116 language machine" by a micro- 
program stored in a "2100 micromachine" — is that 
the hardware is simpler, hence more reliable, and 
considerably more flexible: changing the visible ma- 
chine requires microcode changes or additions, not 
rewiring, layout, new parts, and so on. 

In appearance, the HP 2100 is a rather conventional 
minicomputer (Clark Kent appeared to be a rather 
conventional reporter). It may have up to 32K words 
of nonvolatile memory and many IO devices. Its 
machine language is identical to that of the earlier 
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Fig. 1. Analyzing system performance is the first step in 
deciding where to use microcode A common method is to 
use a software-programmable dock to time various opera- 
tions This method requires considerable intuition 

HP 21 IB and its operation speeds are typical of most 
minicomputers. What sets it apart from most other 
minicomputers, however, is that it is a microcoded 
machine, and the user is encouraged to take advan- 
tage of this microcode capability. 45 

The importance of microcode to the user is that it 
makes possible significant performance increases in 
many situations. Performance may mean speed to 
one user, accuracy to another, and a special (lata for- 
mat to a third. For example, the HP 2100's Fast 
FORTRAN Package (FFP), a microcode package imple- 
mented in read-only memory (ROM), yields a speed 
increase of more than 30 times in extended-precision 
floating-point operations. Along with this speed in- 
crease, the user gets a significant increase (approxi- 
mately 900 words) in available memory because oper- 
ations previously performed by machine language 
subroutines are replaced by microcoded instructions 
implemented in ROM. This kind of architectural ex- 
tension requires no hardware extensions such as ex- 
tended arithmetic units or special-purpose processors. 

Microprograms are stored in some form of relatively 
permanent memory. ROMs. PROMs. and RAMs are 
used, in addition to the somewhat less structured pro- 
grammable logic arrays (PLAs). When RAMs are 
used, they are sometimes called writable control store 
(WCS). This special memory is generally several 
times faster than the computer's main memory, where 
machine language programs and data reside. It is 
also usually wider (some machines use 200-bit-wide 
microinstructions) to allow for substantial paral- 
lelism of operations. 



In the HP 2100, microcode is organized into four 
256-word modules. Each word is 24 bits wide. 
Module 0 defines the base instruction set. It is im- 
plemented in ROM and is always present. Modules 1, 
2. and 3 are for extensions to the base set. They may 
be absent, or may be implemented in ROM. PROM, or 
WCS. Although all run at 196 nanoseconds per micro- 
instruction. WCS has a speed advantage since its 
microprograms may be dynamically tuned for speed. 
However, it is volatile and therefore requires copies 
of its microprograms in the computer's main memory, 
The speed advantage of microcode in the 2100 
comes from four sources: 

The fast microprocessor: 196 ns/microinstruction 
is five million microinstructions per second. 
Storage of microcoded programs outside of main 
memory. This eliminates competition of programs 
and data for main memory cycles and thus doubles 
the speed of most instructions. 
Provision for parallel operation of the computing 
resources — for example, calculation during a 
memory access. 

The ability to create special-purpose assembly 
language instructions and thereby overcome per- 
formance compromises that may have been made 
when the basic instruction set was designed. 

Analyzing Where to Microcode 

It is easy to be misled by intuition in the area of tim- 
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Fig. 2. A useful tool tor timing analysis is a hardware 
Breakpoint register, which emits a pulse whenever the 
computer program accesses the memory location set 
into the switch register The comparator output may be 
displayed on an oscilloscope or be ted to a computer, 
even the one being measured 
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ing. Quite often our feelings about where computer 
programs spend their time are wrong, primarily be- 
cause we ask the wrong questions. It is important to 
know if a speedup by a factor of five in a particular 
subroutine will effect a speed increase of 5. or 1.5. or 
1.0005 at the system level. 

Fortunately, there are techniques that allow us to 
measure system performance, localize areas with 
highest system performance leverage, and predict re- 
liably what system performance increment to expect 
from microcode (or assembly language, or simple 
program reorganization, for that matter). System per- 
formance, in this context, means basically the timing 
associated with user-visible operations. For example, 
in the eyes of a user processing SONAR echoes in real 
time, the per-echo processing time is a system char- 
acteristic; the timing of subroutines is relevant only 
in relation to this. 

By far the most common technique to measure sys- 
tem timing is to use a hand-held watch. Unfortunately, 
this method collapses all information about timing 
into a single number, time. A second common method 
is to use a software-programmable clock to time var- 
ious operations (see Fig. 1). Many computers contain 
programmable clocks with millisecond or micro- 
second resolution. These require considerable intui- 
tion in deciding what to measure and what to change. 
Also, there is no easy way to predict what the effect of 
a change will be. For example, the user may recode a 
large matrix inversion and eigenvalue package much 
more efficiently, only to find that the system timing 
really depended on a tiny vector-dot-product routine 
used by the matrix inversion routine. 

An extremely useful tool for timing analysis is a 
hardware breakpoint register, such as the HP 1067BA 
or the American Asian BPR-2100 (see Figs. 2 and 3). 
This device emits a pulse every time the address set 
into its 16 switches matches the M (memory address) 
register. One can determine the time in microseconds 
spent in any subroutine by setting its entry address 
into the switches and timing the pulse separation on 
any scope. The entry address is accessed via the fSB 
instruction when the routine is entered and via the 
IMP.I instruction when the routine is exited. Thus 
the breakpoint register emits a pulse at the beginning 
and end of the subroutine. The breakpoint register can 
also answer such questions as "Is this section of code 
used?." "Did the DMA completion interrupt happen 
before or after some external event?." and so on. 

Perhaps the most useful tool for timing analysis is 
the activity profile (see Fig. 4). This is a plot showing 
the percentage of time spent in each area of memory. It 
not only localizes timing hot-spots, it measures their 
intensity. 

One of the simplest ways to generate an activity 
profile is simply to push the HALT switch ten or 
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Fig. 3. Setting a subroutine s entry address into the switches 
ot a breakpoint register makes it possible to see how olten 
that subroutine is used and what its execution time is Top 
photo shows this subroutine is invoked about every 0 5 milli- 
second Bottom photo shows subroutine is about 70 micro- 
seconds long; pulses are entry, parameter pickup, and exit. 

twenty times while the system is operating and write 
down the program address register contents each 
time the machine is halted. Normally some range of P- 
values will stand out. This, along with a printout of 
the subroutines loaded into various areas of memory, 
points to the programs that need attention. It also sug- 
gests what speed improvement is possible. For exam- 
ple, if seven out of twenty halts found P in the .FLUN 
floating-point unpacking subroutine, then there 
would be speed increase of about 7/20 or 35% if the 
.FLUN routine were made infinitely fast. 

A fancier version of this procedure uses the com- 
puter to measure itself. I have used this technique on 
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Fig. 4. The activity profile, a plot showing the percentage ol 
time spent in each area ol memory, is an excellent tool lor 
timing analysis Generating it requires that the program 
labeled ACP run at the same time as the user's program Any 
computer's interrupt system provides this capability. 

several different machines. The IBM 360/67 required 
creation of a high-priority asynchronous task running 
off the time-of-day clock. The CDC 6600 used an inter- 
rupt processor resident in one of its peripheral pro- 
cessing units (PPUs). and the CDC 3800 used a con- 
ventional interrupt processor. In the HP 2100. a short 
assembly language subroutine (about 50 words long) 
that used the computer's interrupt system to read an 
endless loop of paper tape was written. As each inter- 
rupt occurred (approximately every three milli- 
seconds using a 300-cps photoreader). the user pro- 
gram would pause, the interrupt subroutine would 
read the P-register and increment a histogram stored 
in a 256-word buffer, and then the user program 
would continue. 

Fig. 5 shows this technique applied to a benchmark 
portion of a Fortran program. The CALL to ACP 
defines the range of P-register values to be included 
in the histogram and begins the test. The CALL to 



CALL ACPCIPMIN, IRHO, IBUF,256» 10B) 
IL00P=1 

DO 30 I=1»IL00P 

DO 25 J= \, 10 

DO 25 K= 1,256 
25 JRPPCK )=AL0G( FLOAT ( I RPPCK, J) > )« 1 00. 
30 CONTINUE 

CALL ACP0CSUM) 



Fig. 5. A potion ol a user's FORTRAN program with CALL 
statements to start and stop ACP processes. 



ACPO ends the test and produces the plots shown in 
Figs. 6. 7, and 8. 

Fig. 6 shows that the only area in the entire machine 
that affects system timing is located near memory lo- 
cation 32000. This area is expanded in Fig. 7. Note that 
both the location and the intensity of timing hot 
spots stand out. Fig. 8 shows the effect of adding the 
floating point ROMs. 

Upgrading a Computer-Based Signal Processor 

The HP 5451B (Fig. 9) is a computer-based digital 
signal processor. Its calculator-like keyboard allows 
the user to observe, synthesize, and manipulate wave- 
forms in both the time domain and the frequency do- 
main. Internally, all waveforms are represented digi- 
tally to provide large dynamic range (16 bits, equiva- 
lent to 96 dB) and the ability to perform precise 
manipulations. 

Fourier analyzers are widely used to solve problems 
in mechanical vibration, signature analysis, modal 
analysis, impact testing, digital shaker control, noise 
source detection, underwater acoustics, servo testing, 
communications, filter design, and many other areas. 

An objective of the 545 IB project was to use the mi- 
crocode capability of the 2100 computer to provide a 
factor of two or three improvement in speed over the 
already optimized 5451A software. By using factory 
programmed PROMs to create several new machine 
language instructions, and then using these new in- 
structions in some of our time-critical software mod- 
ules, we hoped to be able to pass on the speed im- 
provement to the user at zero additional cost. 

The first engineering task was to develop a method 
to measure processing performance in a way that 
would allow comparison of various processing tech- 
niques. The methods developed were described in 
the preceding section. Applied to the 5451A, they 
produced results like Figs. 10 and 11. 

At the same time we assembled the necessary hard- 
ware: a writable control store (VVCS) for development 
of microprograms, a PROM writer for later "burning" 
the debugged microprograms onto PROMs, and an 
HP 2100 Computer. 

After a time we began to get an intuitive feel for 
what we could do with microcode. During the calcu- 
lation of a power spectrum, one has to convert an array 
of complex numbers (A + jB) into an array of magnitude- 
squares [A 2 + B 2 ]. The 2100 machine language 
MPY instruction takes about 11 microseconds, but 
we were able to do the entire conversion, including 
multiplication, double-precision addition, memory 
access, and array subscripting at only 6.5 /xs per 
word. Only 30 microinstructions were required. 

A complicated in-place sorting operation is re- 
quired in the fast Fourier transform (FFT). Each word 
(typically there are 1024 words) is moved to its bit- 
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Fig. 6. Activity profile generated 
by ACP The horizontal axis shows 
memory locations 0 to 40000a 
(16384 to). The subroutines lo- 
cated between 3 1200a and 32200a. 
approximately, are the only ones 
that influence the execution time 
of this user 's benchmark program 
The little bump at 25400a is the 
benchmark program itselt 



reversed image; thus the contents of address 0001 t 
moves to address 1000,. the contents of address 
0010;, to 0100,. the contents of address 0011] 
to 1100 2 . etc. The machine language program that 
performed this in-place sort took about 80 ^s/word 
and required about 60 instructions. The new machine 
language program takes 4 /its/word and requires only 
ten instructions. One new machine language instruc- 
tion was created with a 30-microinstruction micro- 
program which is not only faster but also smaller than 
its machine language counterpart. 

Fig. 12 compares the speed improvements and in- 



cremental costs of firmware and special-purpose 
hardware methods of improving the speed of the 
Fourier analyzer. 

As we saw more uses for microcode, we realized 
that ROMs were too inflexible in our application. We 
did not have a static problem to solve, such as emulat- 
ing the 2116 instruction set. Furthermore, standard 
programming techniques for speed enhancement are 
much easier to apply with WCS than with ROM. As a 
result, our approach changed. To provide a structure 
that would allow any future software development ef- 
fort (by factory, field, or user) to comprise both a ma- 
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Fig. 7. An expanded view of the 
area around 32000a m Fig 6 Re- 
solutjon is two words . compared to 
fOO words m Fig 6 Nonce how me 
areas with system performance 
leverage stand out The PACK 
suorouune takes about 40% of the 
lime, but the MAP subroutine, 
which resolves subscripts, has 
essentially zero leverage for 
this benchmark 



21 

© Copr. 1949-1998 Hewlett-Packard Co. 





_ inn°. 

i i I T- 1 


( 


1 


10k 


1 

20k 




30k 


1 

40k 
















c 




1 

10k 


1 

20k 




30k 


1 

40k 



Fig. 8. Activity profile tor the benchmark of Figs. 6 and 7 
with floating-point firmware replacing the FADSB. FMP 
FLOAT, FIX. and FLUN routines and eliminating PACK 
entirely The benchmark runs six times faster, an improvement 
that could have been predicted from Fig 7 Subroutine ALOG 
now takes 70% of the time, most of it in a 28-word section. 
MAP takes about 10% of the time, and the user's program 
about 20% Thus there is still room for improvement 




Fig. 9. Thanks to the microcode capability of the HP2100S 
computer, the 545 IB Fourier Analyzer is ten times taster 
than the 5451 A 
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Fig. 10. Activity profile tor a benchmark process used in the 
5451 A shows that 80% of the time is spent in subroutines 
near memory location lOOOOt 

chine language portion and a microcode portion, and 
to capitalize on the intrinsic flexibility and higher 
speed potential of writable control store. WCS was 
included in the 5451B hardware configuration. 

A structure that allows the sharing of WCS can 
pose coordination problems. Assume that a program 
uses special machine language instructions defined 
by microcode residing in WCS. Should the program 
be responsible for loading WCS? What if it calls a sub- 
routine that loads WCS with something else? Should 
subroutines be deprived of the use of microcode? If a 
machine interrupt occurs, should an interrupt pro- 
cessor be allowed to use WCS? If some of the WCS mi- 
crocode is committed to PROM to eliminate WCS 
loading time, should the programs using that micro- 
code be changed at all? 

The solution chosen in the 5451B involves the use 
of both PROM and WCS along with the concept of vir- 
tual microcode. Users of special microcoded machine 
language instructions need not be aware of the storage 
medium or the state of WCS. Any assembly language 
routine in the 5451B that uses microcode assumes 
that WCS is loaded with the appropriate micropro- 
grams. If that assumption is true, that microcode is 
executed with zero linkage overhead. If that assump- 
tion is false, an illegal opcode trap occurs, and the 
trap interrupts into an assembly language system sub- 
routine that quickly loads WCS and causes the no- 
longer-illegal opcode to be re-executed. The dynamic 
character of WCS is invisible to the user, who may 
simply assume that all of the microcode is available 
all of the time. 

The virtual microcode concept required several 
features not present in the normal 2100 architecture: 
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illegal instruction trapping, interrupts not involving 
the I/O structure, a third programmable DMA channel, 
and others. PROMs were microprogrammed to fill this 
need. They contain micro-utilities for parameter pass- 
ing (giving the machine language programmer access 
to invisible registers and the microprngrammer ac- 
cess to global parameters like the location of the oper- 
and stack), illegal-opcode trapping, pseudo-interrupts 
(allowing microcode to call assembly language rou- 
tines). pseudo-DMA (500 kHz rate without requiring 
any special hardware), and other capabilities. 

This new set of capabilities allows the user to ignore 
the operation of loading WCS as well as the time 
"lost" during the loading. For example, it is possible 
for the execution time of a subroutine as short as ten 
milliseconds to be cut by a factor of five or ten, even 
including the loading of WCS. In fact, during the 
most time-critical operations in the 5451B Fourier 
Analyzer. WCS may be reloaded as often as every 10 
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Fig. 12. Comparing special- purpose hardware with firm- 
ware lor speeding Fourier analyzer operation 



Fig. 11. Expanded view ol me 
area around 10000e in Fig 10 
Elementary operations that de- 
termine system speed include 
complex addition, subtraction, 
and multiplication, double-preci- 
sion add-test-round, and trigono- 
metric interpolation. 

to 50 milliseconds. The slight cost of loading is more 
than offset by the additional speed available and by 
the flexibility that allows different microprogram- 
ming efforts (application groups, users, the factory) 
to work together on a problem solution. 
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